<!-- 绑定弹窗 -->

<template>
  <WebModal path="bind" small>
    <WebForm path="bind" class="MapPoint-BindForm">
      <MyInherit />

      <MyMap />
    </WebForm>
  </WebModal>
</template>

<script>
// ============================== 导入依赖 ============================== //

import CORE from '@/CORE'

// ============================== 导出组件 ============================== //

export default {
  /**
   * 名称定义 (实际使用名称)
   */
  name: 'BindModal',

  /**
   * 混入列表 (配置选项合并)
   */
  mixins: [CORE.mixWeb('bind'), CORE.mixInfo('bind')],

  /**
   * 组件导入 (Abc.vue + Abc/index.vue)
   */
  ...CORE.components(require.context('./', true, /vue$/)),

  /**
   * 监听属性 (深度 deep 首次 immediate)
   */
  watch: {
    /**
     * 监听继承区域
     */
    'one.parentAreaId': {
      immediate: true,
      handler(areaId) {
        this.infoParam.areaId = areaId
        this.startInfo() // 更新继承的地图信息
      },
    },

    /**
     * 监听弹窗打开
     */
    visible: {
      immediate: true,
      handler(visible) {
        if (visible) {
          this.infoParam.areaId = this.one.parentAreaId
          this.startInfo() // 更新继承的地图信息
        }
      },
    },
  },
}
</script>

<style lang="scss">
@import './index.scss';
</style>
